/*
  学习目标：受控组件 - 多表单元素代码优化
*/

import React from 'react';

export default class App extends React.Component {
  state = {
    username: 'zs',
    desc: '',
    city: '2',
    isSingle: true,
  };

  handleChange = (e) => {
    const { name, type, checked, value } = e.target;
    this.setState({
      [name]: type === 'checkbox' ? checked : value,
    });
  };

  render() {
    // 解构state快捷键:  cs
    const { username, desc, city, isSingle } = this.state;
    return (
      <div>
        姓名：
        <input name="username" type="text" value={username} onChange={this.handleChange} />
        <br />
        描述：<textarea name="desc" value={desc} onChange={this.handleChange}></textarea>
        <br />
        城市：
        <select name="city" value={city} onChange={this.handleChange}>
          <option value="1">北京</option>
          <option value="2">上海</option>
          <option value="3">广州</option>
          <option value="4">深圳</option>
        </select>
        <br />
        是否单身：
        <input name="isSingle" type="checkbox" checked={isSingle} onChange={this.handleChange} />
      </div>
    );
  }
}
